এক্সেল VBA দিয়ে চার্ট এনিমেশন তৈরি

Microsoft Technologies - এক্সেল চার্ট  (Excel Charts) চার্ট ডেটা এনিমেশন (Chart Data Animation) |
64
64

এক্সেল VBA (Visual Basic for Applications) ব্যবহার করে আপনি আপনার চার্টে এনিমেশন প্রভাব যোগ করতে পারেন। এনিমেশন দ্বারা চার্টের উপাদানগুলো ধীরে ধীরে দেখানো যায়, যা সাধারণত ডেটা প্রেজেন্টেশনে দর্শকদের মনোযোগ আকর্ষণ করতে সহায়তা করে। VBA কোড ব্যবহার করে আপনি বিভিন্ন এনিমেশন ইফেক্ট যেমন, ডেটা সিরিজের ধাপে ধাপে আপিয়ার (appear) হওয়া, কালার পরিবর্তন, বা বার/কলামের সাইজ পরিবর্তন তৈরি করতে পারেন।


VBA দিয়ে চার্ট এনিমেশন তৈরির পদক্ষেপ

এক্সেল VBA ব্যবহার করে চার্টে এনিমেশন যুক্ত করার জন্য আপনাকে কিছু কোড লিখতে হবে, যা চার্টের ডেটা সিরিজকে ধীরে ধীরে পরিবর্তন করবে। নিচে একটি সাধারণ এনিমেশন তৈরি করার প্রক্রিয়া দেওয়া হলো:


১. VBA এডিটর ওপেন করা

  1. VBA এডিটর খুলুন:
    • এক্সেল শীটে Alt + F11 চাপুন, এটি VBA এডিটর খুলবে।
    • যদি আপনি নতুন একটি মডিউল যোগ করতে চান, তবে Insert মেনু থেকে Module নির্বাচন করুন।

২. VBA কোড লিখা

  1. VBA কোড যুক্ত করুন: নিচে একটি উদাহরণ কোড দেওয়া হলো যা কলাম চার্টে এনিমেশন তৈরি করবে। কোডটি ডেটা সিরিজগুলোকে একটি এক্সপোনেনশিয়াল গতি দিয়ে ধীরে ধীরে প্রদর্শন করবে।
Sub AnimateChart()
    Dim chartObj As ChartObject
    Dim series As Series
    Dim i As Long
    Dim delay As Double
    
    ' আপনার চার্ট সিলেক্ট করুন
    Set chartObj = ActiveSheet.ChartObjects("Chart 1") ' "Chart 1" এর পরিবর্তে আপনার চার্টের নাম ব্যবহার করুন
    Set series = chartObj.Chart.SeriesCollection(1) ' প্রথম সিরিজ নির্বাচন
    
    ' ডেটা সিরিজের উপর এনিমেশন প্রভাব প্রয়োগ
    delay = 0.1 ' বিলম্ব (সেকেন্ড)
    
    ' সিরিজের প্রতিটি পয়েন্ট ধীরে ধীরে প্রদর্শন
    For i = 1 To series.Points.Count
        series.Points(i).Format.Fill.Transparency = 1 ' পয়েন্ট গোপন করা
        chartObj.Chart.Refresh
        series.Points(i).Format.Fill.Transparency = 0 ' পয়েন্ট প্রদর্শন করা
        DoEvents
        Application.Wait (Now + TimeValue("0:00:" & delay)) ' বিলম্ব যোগ করা
    Next i
    
    ' এনিমেশন সম্পন্ন হলে চার্ট পুনরায় রিফ্রেশ করা
    chartObj.Chart.Refresh
End Sub

৩. কোড রান করা

  1. কোড রান করুন:
    • কোডটি লিখে F5 চাপুন বা Run বাটনে ক্লিক করুন।
    • এটি আপনার চার্টে এনিমেশন প্রভাব যোগ করবে। এখানে প্রতিটি ডেটা পয়েন্টের উপর ধীরে ধীরে এনিমেশন প্রভাব প্রয়োগ করা হবে।

৪. কাস্টমাইজেশন এবং উন্নতি

  1. নতুন ডেটা সিরিজ যুক্ত করা: আপনি যদি একাধিক সিরিজে এনিমেশন প্রভাব প্রয়োগ করতে চান, তবে SeriesCollection(1) অংশে সিরিজ নম্বর পরিবর্তন করতে পারেন, যেমন SeriesCollection(2) এবং এর পরবর্তী সিরিজগুলো।
  2. এনিমেশন স্পিড পরিবর্তন: delay ভেরিয়েবলটির মান পরিবর্তন করে আপনি এনিমেশনের গতি নিয়ন্ত্রণ করতে পারেন। মান বেশি হলে এনিমেশন ধীর হবে, এবং কম হলে দ্রুত হবে।
  3. এনিমেশন ইফেক্ট পরিবর্তন: আপনি Format.Fill.Transparency পরিবর্তন করে অন্যান্য প্রভাব যেমন রঙ পরিবর্তন, সাইজ পরিবর্তন বা ইত্যাদি এনিমেশন প্রভাব যোগ করতে পারেন।

৫. উদাহরণ হিসেবে আরও কিছু এনিমেশন

  1. রঙ পরিবর্তন এনিমেশন: আপনি রঙের পরিবর্তন এনিমেশনও যোগ করতে পারেন। নিচে একটি উদাহরণ দেওয়া হলো:
Sub AnimateColorChange()
    Dim chartObj As ChartObject
    Dim series As Series
    Dim i As Long
    
    Set chartObj = ActiveSheet.ChartObjects("Chart 1") ' "Chart 1" আপনার চার্টের নাম
    Set series = chartObj.Chart.SeriesCollection(1) ' প্রথম সিরিজ
    
    For i = 1 To series.Points.Count
        series.Points(i).Format.Fill.ForeColor.RGB = RGB(255, 0, 0) ' রঙ পরিবর্তন (লাল)
        chartObj.Chart.Refresh
        Application.Wait (Now + TimeValue("0:00:01")) ' বিলম্ব
        series.Points(i).Format.Fill.ForeColor.RGB = RGB(0, 255, 0) ' রঙ পরিবর্তন (সবুজ)
        chartObj.Chart.Refresh
        Application.Wait (Now + TimeValue("0:00:01")) ' বিলম্ব
    Next i
End Sub
  1. কলাম সাইজ পরিবর্তন এনিমেশন: আপনি কলামের সাইজ বা উচ্চতা পরিবর্তন করতে পারেন। এখানে একটি উদাহরণ:
Sub AnimateBarSize()
    Dim chartObj As ChartObject
    Dim series As Series
    Dim i As Long
    
    Set chartObj = ActiveSheet.ChartObjects("Chart 1") ' "Chart 1" আপনার চার্টের নাম
    Set series = chartObj.Chart.SeriesCollection(1) ' প্রথম সিরিজ
    
    For i = 1 To series.Points.Count
        series.Points(i).Format.Fill.Transparency = 1 ' প্রথমে লুকানো
        chartObj.Chart.Refresh
        series.Points(i).Format.Fill.Transparency = 0 ' এরপর দৃশ্যমান করা
        series.Points(i).Format.Fill.ForeColor.RGB = RGB(0, 255, 0) ' সাইজ পরিবর্তন (রঙ পরিবর্তন করা যায়)
        Application.Wait (Now + TimeValue("0:00:01"))
    Next i
End Sub

উপসংহার

এক্সেল VBA দিয়ে চার্ট এনিমেশন তৈরি করলে আপনি আপনার প্রেজেন্টেশনে একটি আরও ইন্টারঅ্যাকটিভ এবং আকর্ষণীয় উপস্থাপনা তৈরি করতে পারবেন। VBA কোডের মাধ্যমে আপনি বিভিন্ন এনিমেশন ইফেক্ট যেমন ধীরে ধীরে ডেটা পয়েন্ট প্রদর্শন, রঙ পরিবর্তন, সাইজ পরিবর্তন এবং আরও অনেক কিছু তৈরি করতে পারেন। এর ফলে আপনার ডেটা বিশ্লেষণ আরও প্রাণবন্ত এবং দর্শনীয় হয়ে উঠবে।

Content added By
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion